package com.ruoyi.common.core.controller;

import java.beans.PropertyEditorSupport;
import java.io.ByteArrayInputStream;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.stream.Collectors;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.ruoyi.common.constant.HttpStatus;
import com.ruoyi.common.core.domain.AjaxResult;
import com.ruoyi.common.core.domain.model.LoginUser;
import com.ruoyi.common.core.page.PageDomain;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.core.page.TableSupport;
import com.ruoyi.common.utils.DateUtils;
import com.ruoyi.common.utils.PageUtils;
import com.ruoyi.common.utils.SecurityUtils;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.common.utils.sql.SqlUtil;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpression;
import javax.xml.xpath.XPathFactory;

/**
 * web层通用数据处理
 * 
 * @author ruoyi
 */
public class BaseController {
    protected final Logger logger = LoggerFactory.getLogger(this.getClass());

    /**
     * 将前台传递过来的日期格式的字符串，自动转化为Date类型
     */
    @InitBinder
    public void initBinder(WebDataBinder binder) {
        // Date 类型转换
        binder.registerCustomEditor(Date.class, new PropertyEditorSupport() {
            @Override
            public void setAsText(String text) {
                setValue(DateUtils.parseDate(text));
            }
        });
    }

    /**
     * 设置请求分页数据
     */
    protected void startPage() {
        PageUtils.startPage();
    }

    /**
     * 设置请求排序数据
     */
    protected void startOrderBy() {
        PageDomain pageDomain = TableSupport.buildPageRequest();
        if (StringUtils.isNotEmpty(pageDomain.getOrderBy())) {
            String orderBy = SqlUtil.escapeOrderBySql(pageDomain.getOrderBy());
            PageHelper.orderBy(orderBy);
        }
    }

    /**
     * 清理分页的线程变量
     */
    protected void clearPage() {
        PageUtils.clearPage();
    }


    protected TableDataInfo getDIYPageTable(List<?> list) {
        TableDataInfo rspData = new TableDataInfo();
        rspData.setCode(HttpStatus.SUCCESS);
        rspData.setMsg("查询成功");
        long startPage = (long)(PageUtils.getLocalPage().getPageNum()-1)*PageUtils.getLocalPage().getPageSize();
        List<?> rows = list.stream().skip(startPage).limit(PageUtils.getLocalPage().getPageSize()).collect(Collectors.toList());
        rspData.setRows(rows);
        rspData.setTotal(list.size());
        return rspData;
    }
    /**
     * 响应请求分页数据
     */
    @SuppressWarnings({"rawtypes", "unchecked"})
    protected TableDataInfo getDataTable(List<?> list) {
        TableDataInfo rspData = new TableDataInfo();
        rspData.setCode(HttpStatus.SUCCESS);
        rspData.setMsg("查询成功");
        rspData.setRows(list);
        rspData.setTotal(new PageInfo(list).getTotal());
        return rspData;
    }

    /**
     * 返回成功
     */
    public AjaxResult success() {
        return AjaxResult.success();
    }

    /**
     * 返回失败消息
     */
    public AjaxResult error() {
        return AjaxResult.error();
    }

    /**
     * 返回成功消息
     */
    public AjaxResult success(String message) {
        return AjaxResult.success(message);
    }

    /**
     * 返回成功消息
     */
    public AjaxResult success(Object data) {
        return AjaxResult.success(data);
    }

    /**
     * 返回失败消息
     */
    public AjaxResult error(String message) {
        return AjaxResult.error(message);
    }

    /**
     * 返回警告消息
     */
    public AjaxResult warn(String message) {
        return AjaxResult.warn(message);
    }

    /**
     * 响应返回结果
     *
     * @param rows 影响行数
     * @return 操作结果
     */
    protected AjaxResult toAjax(int rows) {
        return rows > 0 ? AjaxResult.success() : AjaxResult.error();
    }

    /**
     * 响应返回结果
     *
     * @param result 结果
     * @return 操作结果
     */
    protected AjaxResult toAjax(boolean result) {
        return result ? success() : error();
    }

    /**
     * 页面跳转
     */
    public String redirect(String url) {
        return StringUtils.format("redirect:{}", url);
    }

    /**
     * 获取用户缓存信息
     */
    public LoginUser getLoginUser() {
        return SecurityUtils.getLoginUser();
    }

    /**
     * 获取登录用户id
     */
    public Long getUserId() {
        return getLoginUser().getUserId();
    }

    /**
     * 获取登录部门id
     */
    public Long getDeptId() {
        return getLoginUser().getDeptId();
    }

    /**
     * 获取登录用户名
     */
    public String getUsername() {
        return getLoginUser().getUsername();
    }

    /**
     * 从节点中查找标签对应节点
     * @param node
     * @param label
     * @return
     */
    public Node getXmlLabelNode(Node node, String label) {
        Node labelNode = null;
        if (node !=null) {
            // 通过标签名获取system-id节点的值
            labelNode = node.getFirstChild();
            while (labelNode != null && !label.equalsIgnoreCase(labelNode.getNodeName())) {
                labelNode = labelNode.getNextSibling();
            }
            return labelNode;
        }
        return labelNode;
    }

    /**
     * 从节点中查找标签对应值
     * @param node
     * @param label
     * @return
     */
    public String getXmlLabelValue(Node node, String label) {
        if (node == null) {
            return null;
        }
        String value = null;
        // 通过标签名获取system-id节点的值
        Node labelNode = node.getFirstChild();
        while (labelNode!= null &&!label.equalsIgnoreCase(labelNode.getNodeName())) {
            labelNode = labelNode.getNextSibling();
        }
        if (labelNode!= null) {
//                        System.out.println(labelNode+":" + systemIdNode.getTextContent());
            value = labelNode.getTextContent();
        }
        return value;
    }

    /*public List<String> findNetConfXmlNodes(String xml, String nodePath) {
        List<String> list = new ArrayList<>();*/
    public NodeList findNetConfXmlNodes(String xml, String nodePath) {
//        List<String> list = new ArrayList<>();
        NodeList nl = null;
        try {
            // 将字符串转换为InputStream
            ByteArrayInputStream input = new ByteArrayInputStream(xml.toString().getBytes("UTF-8"));

            // 创建DocumentBuilderFactory对象
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            // 创建DocumentBuilder对象
            DocumentBuilder builder = factory.newDocumentBuilder();
            // 解析输入流获取Document对象
            Document document = builder.parse(input);

            // 创建XPathFactory对象
            XPathFactory xPathfactory = XPathFactory.newInstance();
            // 创建XPath对象
            XPath xpath = xPathfactory.newXPath();
            // 编译XPath表达式
            XPathExpression expr = xpath.compile(nodePath);

            // 执行XPath表达式，获取结果
            nl = (NodeList) expr.evaluate(document, XPathConstants.NODESET);

            /*// 遍历结果
            for (int i = 0; i < nl.getLength(); i++) {
                System.out.println(nl.item(i).getTextContent());
                list.add(nl.item(i).getTextContent());
            }*/
        } catch (Exception e) {
            logger.error("获取xml节点失败", e);
        }
        return nl;
    }

}
